## **CLAIMS**

## What is claimed is:

| 5 | W N        |
|---|------------|
|   | an'        |
|   |            |
|   | 1,2        |
|   | 4.4        |
|   | ľā         |
|   | ===        |
|   | 2: 55      |
|   | 14         |
|   | I.T        |
|   | l.T        |
|   | #i         |
|   | 13         |
|   | 14         |
|   | <u>1</u> 4 |

| 1\ A thermal management system for an integrated circuit die, comprising:                |  |  |
|------------------------------------------------------------------------------------------|--|--|
| a temperature detection element formed directly on said integrated circuit die, said     |  |  |
| temperature detection element including at least one temperature sensor having an        |  |  |
| output; \                                                                                |  |  |
| a power modulation element formed directly on said integrated circuit die and configured |  |  |
| to reduce power consumption of said integrated circuit die in response to a logical      |  |  |
| change in state at said output of said at least one temperature sensor;                  |  |  |
| a control element formed directly on said integrated circuit die, said control element   |  |  |
| including at least one register providing an enable/disable bit for said thermal         |  |  |
| management system; and                                                                   |  |  |
| a visibility element formed directly on said integrated circuit die and configured to    |  |  |
| indicate a status of said output of said at least one temperature sensor.                |  |  |
|                                                                                          |  |  |
| 2. The system of claim 1, said at least one temperature sensor comprising:               |  |  |

- a reference voltage source providing a reference voltage;
  a programmable voltage source providing a programmable voltage proportional to a
  temperature of said integrated circuit die; and
  a comparator having one input coupled via a first signal line to said reference voltage
  source and another input coupled via a second signal line to said programmable
  voltage source, said comparator configured to provide said logical change in state
  at said output of said at least one temperature sensor in response to said
  programmable voltage substantially equaling said reference voltage.
- 3. The system of claim 2, further comprising a pulse dampener coupled to said first signal line and configured to at least partially remove electrical noise from said reference voltage.

- 4. The system of claim 2, further comprising an analog filter coupled to said second signal line and said first signal line, said analog filter configured to detect voltage spikes present in said reference voltage and to add substantially identical voltage spikes to said programmable voltage.
- 5. The system of claim 2, further comprising a digital filter coupled to an output of said comparator, said digital filter including an up-down counter configured to count clock pulses, said up-down counter configured to increment once for each clock pulse detected when said comparator output is at a logical high and to decrement once for each clock pulse detected when said comparator output is at a logical low.
- 6. The system of claim\1, said control element further including another register selected from a group consisting of a register configured to selectively disengage a specified portion of said thermal management system, a register configured to enable said thermal management system in response to an occurrence of an external event, a register configured to force said thermal management system active while overriding a disable bit provided by said at least one register, and a register configured to allow external software and hardware to enable said thermal management system.
- 7. The system of claim 1, said visibility element including at least one device selected from a group consisting of a register configured to indicate said status of said temperature sensor output, a register providing a sticky bit, a counter configured to count a number of lost clock cycles resulting from operation of said thermal management system, and circuitry configured to generate an interrupt when said temperature sensor output transitions to a different logical state.

3

4

5

1

2

3

4

5

6

7

8

9

10

11

12

13

14

| 8. The system of claim 1, said power modulation element configured to                             |
|---------------------------------------------------------------------------------------------------|
| lower a supply voltage to said integrated circuit die, lower a frequency of a clock signal        |
| provided by internal clock circuitry on said integrated circuit die, perform clock gating of      |
| said clock signal provided by said internal clock circuitry, perform clock throttling of said     |
| clock signal provided by said internal clock circuitry, selectively block clock pulses of         |
| said clock signal provided by said internal clock circuitry, disable at least one of a            |
| plurality of functional units on said integrated circuit die, limit instructions sent to at least |
| one of said plurality of functional units on said integrated circuit die, or change a             |
| behavior of at least one of said plurality of functional units on said integrated circuit die.    |
|                                                                                                   |

9. A microprocessor, comprising:

a die having a plurality of functional units formed thereon;

internal clock circuitry formed on said die and coupled to at least one of said plurality of

functional units; and

a thermal management system formed directly on said die, comprising:

a temperature detection element including at least one temperature sensor having an output;

a power modulation element configured to reduce power consumption of at least one of said functional units in response to a logical change in state at said output of said at least one temperature sensor;

a control element including at least one register providing an enable/disable bit for said thermal management system; and

a visibility element configured to indicate a status of said output of said at least one temperature sensor.

| 1 | 10. The microprocessor of claim 9, said at least one temperature sensor                 |
|---|-----------------------------------------------------------------------------------------|
| 2 | comprising:                                                                             |
| 3 | a reference voltage source providing a reference voltage;                               |
| 4 | a programmable voltage source providing a programmable voltage proportional to a        |
| 5 | temperature of said die; and                                                            |
| 5 | a comparator having one input coupled via a first signal line to said reference voltage |
| 7 | source and another input coupled via a second signal line to said programmable          |
| 3 | voltage source, said comparator configured to provide said logical change in state      |
| 9 | at said output of said at least one temperature sensor in response to said              |
| ) | programmable voltage substantially equaling said reference voltage.                     |

- 11. The microprocessor of claim 10, further comprising a pulse dampener coupled to said first signal line and configured to at least partially remove electrical noise from said reference voltage.
- 12. The microprocessor of claim 10, further comprising an analog filter coupled to said second signal line and said first signal line, said analog filter configured to detect voltage spikes present in said reference voltage and to add substantially identical voltage spikes to said programmable voltage.
- 13. The microprocessor of claim 10, further comprising a digital filter coupled to an output of said comparator, said digital filter including an up-down counter configured to count clock pulses, said up-down counter configured to increment once for each clock pulse detected when said comparator output is at a logical high and to decrement once for each clock pulse detected when said comparator output is at a logical low.

3

4

5

6 7

2

3

4

5

6

1

2

3

4

5

6

7

- 14. The microprocessor of claim 9, said control element further including another register selected from a group consisting of a register configured to selectively disengage a specified portion of said thermal management system, a register configured to enable said thermal management system in response to an occurrence of an external event, a register configured to force said thermal management system active while overriding a disable bit provided by said at least one register, and a register configured to allow external software and hardware to enable said thermal management system.
- 15. The microprocessor of claim 9, said visibility element including at least one device selected from a group consisting of a register configured to indicate said status of said temperature sensor output, a register providing a sticky bit, a counter configured to count a number of lost clock cycles resulting from operation of said thermal management system, and circuitry configured to generate an interrupt when said temperature sensor output transitions to a different logical state.
- 16. The microprocessor of claim 9, said power modulation element configured to lower a supply voltage to said die, lower a frequency of a clock signal provided by said internal clock circuitry, perform clock gating of said clock signal provided by said internal clock circuitry, perform clock throttling of said clock signal provided by said internal clock circuitry, selectively block clock pulses of said clock signal provided by said internal clock circuitry, disable at least one of said plurality of functional units on said die, limit instructions sent to at least one of said plurality of functional units on said die, or change a behavior of at least one of said plurality of functional units on said die.

|                | 1  | 17. A computer system, comprising:                                                        |
|----------------|----|-------------------------------------------------------------------------------------------|
|                | 2  | at least one memory device coupled to a bus;                                              |
|                | 3  | at least one microprocessor coupled to said bus and said at least one memory device, said |
|                | 4  | at least one microprocessor comprising:                                                   |
|                | 5  | a die having a plurality of functional units formed thereon;                              |
|                | 6  | internal clock circuitry formed on said die and coupled to at least one of said           |
|                | 7  | plurality of functional units;                                                            |
| 12             | 8  | a temperature detection element formed directly on said die, said temperature             |
| الرا           | 9  | detection element including at least one temperature sensor having an                     |
| ) <sub>0</sub> | 10 | output;                                                                                   |
| N              | 11 | a power modulation element formed directly on said die and configured to reduce           |
| ]_             | 12 | power consumption of at least one of said functional units in response to a               |
| 14<br>14       | 13 | logical change in state at said output of said at least one temperature                   |
| n Co Co Co     | 14 | sensor;                                                                                   |
|                | 15 | a control element formed directly on said die, said control element including at          |
| 1.11<br>1.11   | 16 | least one register providing an enable/disable bit for said thermal                       |
| 11             | 17 | management system; and                                                                    |
|                | 18 | a visibility element formed directly on said die and configured to indicate a status      |
|                | 19 | of said output of said at least one temperature sensor, said temperature                  |
| 17             | 20 | detection, power modulation, control, and visibility elements comprising a                |
| ű              | 21 | thermal management system for said die.                                                   |
|                |    |                                                                                           |

2

3

1

2

3

4

1

2

3

4

5

6

The computer system of claim 17, said at least one temperature sensor 18. 1 2 comprising: a reference voltage source providing a reference voltage; 3 a programmable voltage source providing a programmable voltage proportional to a 4 temperature of said die; and 5 6 a comparator having one input coupled via a first signal line to said reference voltage source and another input coupled via a second signal line to said programmable 7 voltage source, said comparator configured to provide said logical change in state 8 9 at said output of said at least one temperature sensor in response to said programmable voltage substantially equaling said reference voltage. 10

- 19. The computer system of claim 18, further comprising a pulse dampener coupled to said first signal line and configured to at least partially remove electrical noise from said reference voltage.
- 20. The computer system of claim 18, further comprising an analog filter coupled to said second signal line and said first signal line, said analog filter configured to detect voltage spikes present in said reference voltage and to add substantially identical voltage spikes to said programmable voltage.
- 21. The computer system of claim 18, further comprising a digital filter coupled to an output of said comparator, said digital filter including an up-down counter configured to count clock pulses, said up-down counter configured to increment once for each clock pulse detected when said comparator output is at a logical high and to decrement once for each clock pulse detected when said comparator output is at a logical low.

3.

- 22. The computer system of claim 17, said control element further including another register selected from a group consisting of a register configured to selectively disengage a specified portion of said thermal management system, a register configured to enable said thermal management system in response to an occurrence of an external event, a register configured to force said thermal management system active while overriding a disable bit provided by said at least one register, and a register configured to allow external software and hardware to enable said thermal management system.
  - 23. The computer system of claim 17, said visibility element including at least one device selected from a group consisting of a register configured to indicate said status of said temperature sensor output, a register providing a sticky bit, a counter configured to count a number of lost clock cycles resulting from operation of said thermal management system, and circuitry configured to generate an interrupt when said temperature sensor output transitions to a different logical state.
- 24. The computer system of claim 17, said power modulation element configured to lower a supply voltage to said die, lower a frequency of a clock signal provided by said internal clock circuitry, perform clock gating of said clock signal provided by said internal clock circuitry, perform clock throttling of said clock signal provided by said internal clock circuitry, selectively block clock pulses of said clock signal provided by said internal clock circuitry, disable at least one of said plurality of functional units on said die, limit instructions sent to at least one of said plurality of functional units on said die, or change a behavior of at least one of said plurality of functional units on said die.

25. A method of performing thermal management on a microprocessor, comprising:

providing an enable bit to a register of a thermal management system to activate said thermal management system;

measuring a temperature on a die of said microprocessor with a sensor of said thermal management system;

providing a logical low at an output of said sensor when said temperature is below a trip point;

providing a logical high at said sensor output when said temperature equals or exceeds said trip point;

engaging a power reduction mechanism to reduce power consumption of said die in response to said logical high at said sensor output; and providing an indication of a logical status of said output of said sensor to an external device.

- 26. The method of claim 25, said engaging a power reduction mechanism comprising an act selected from a group consisting of lowering a supply voltage to said die, lowering a frequency of a clock signal provided by internal clock circuitry of said microprocessor, performing clock gating of said clock signal provided by said internal clock circuitry, performing clock throttling of said clock signal provided by said internal clock circuitry, selectively blocking clock pulses of said clock signal provided by said internal clock circuitry, disabling at least one of a plurality of functional units on said microprocessor, limiting instructions sent to at least one of said plurality of functional units on said microprocessor, and changing a behavior of at least one of said plurality of functional units on said microprocessor.
- 27. The method of claim 25, said providing an enable bit to a register of said thermal management system comprising providing an enable bit to said register from an external operating system.

|   | I.                                                                                          |
|---|---------------------------------------------------------------------------------------------|
| 1 | 28. The method of claim 25, further comprising:                                             |
| 2 | engaging said power reduction mechanism for a specified time period;                        |
| 3 | polling said sensor output after expiration of said specified time period;                  |
| 4 | engaging said power reduction mechanism for at least another said specified time period     |
| 5 | when said sensor output exhibits said logical high; and                                     |
| 6 | halting said power reduction mechanism when said sensor output exhibits said logical        |
| 7 | low;                                                                                        |
| 1 | 29. The method of claim 25, further comprising:                                             |
| 2 | engaging said power reduction mechanism for a specified time period;                        |
| 3 | continuously polling said sensor output after expiration of said specified time period; and |
| 4 | halting said power reduction mechanism when said sensor output exhibits said logical        |
| 5 | low.                                                                                        |
| 1 | 30. The method of claim, 25, further comprising:                                            |
| 2 | providing said logical low at said sensor output when said temperature is below an untrip   |
| 3 | point, said untrip point less than said trip point; and                                     |
| 4 | halting said power reduction mechanism in response to said logical low.                     |
| 1 | The method of claim 25, further comprising:                                                 |
| 2 | coupling an up-down counter to said sensor output;                                          |
| 3 | incrementing said up-down counter once for every clock pulse of said clock signal           |
| 4 | provided by said internal clock circuitry when said sensor output exhibits said             |
| 5 | logical high; and                                                                           |
| 6 | decrementing said up-down counter once for every clock pulse of said clock signal           |
| 7 | provided by said internal clock circuitry when said sensor output exhibits said             |
| 8 | logical low.                                                                                |

| 1  | 32. The method of claim 25, further comprising:                                              |
|----|----------------------------------------------------------------------------------------------|
| 2  | defining a plurality of trip temperatures, a highest of said plurality of trip temperatures  |
| 3  | corresponding to said trip point;                                                            |
| 4  | assigning aplurality of duty cycle values to said plurality of trip temperatures, one duty   |
| 5  | cycle value of said plurality of duty cycle values corresponding to at least one of          |
| 6  | said plurality of trip temperatures; and                                                     |
| 7  | providing a clock signal from said internal clock circuitry exhibiting said one duty cycle   |
| 8  | value in response to said temperature substantially equaling said at least one               |
| 9  | corresponding trip temperature.                                                              |
|    |                                                                                              |
| 1  | 33. The method of claim 25, further comprising counting a number of clock                    |
| 2  | cycles eliminated from an output of said internal clock circuitry resulting from said        |
| 3  | engaging a power reduction mechanism.                                                        |
|    |                                                                                              |
| 1  | 34. An apparatus, comprising:                                                                |
| 2  | a temperature detection element, said temperature detection element including at least       |
| 3  | one temperature sensor having an output;                                                     |
| 4  | a power modulation element, said power modulation element to reduce power                    |
| 5  | consumption of an integrated circuit die in response to a logical change in state a          |
| 6  | said output of said at least one temperature sensor;                                         |
| 7  | a visibility element, said visibility element to indicate a status of said output of said at |
| 8  | least one temperature sensor, said visibility element comprising:                            |
| 9  | a register to indicate said status of said temperature sensor output;                        |
| 10 | a register providing a sticky bit;                                                           |
| 11 | a counter to count a number of lost clock cycles resulting from operation of said            |
| 12 | apparatus; and                                                                               |
| 13 | circuitry to generate an interrupt when said temperature sensor output transitions           |
| 14 | to a different logical state.                                                                |
|    | <b>\</b>                                                                                     |

The apparatus of claim 34, further including a control element, said 1 2 control element comprising: a register providing an enable/disable bit for said apparatus; 3 4 a register configured to selectively disengage a specified portion of said apparatus; a register configured to enable said apparatus in response to an occurrence of an external 5 event; a register configured to force said apparatus active while overriding a disable bit provided 8 at said enable/disable bit; and a register configured to allow external software and hardware to enable said apparatus. 9 The system of claim 34, said power modulation element configured to 1 36. 2 lower a supply voltage to said integrated circuit die, lower a frequency of a clock signal

provided by internal clock circuitry on said integrated circuit die, perform clock gating of said clock signal provided by said internal clock circuitry, perform clock throttling of said clock signal provided by said internal clock circuitry, selectively block clock pulses of said clock signal provided by said internal clock circuitry, disable at least one of a plurality of functional units on said integrated circuit die, limit instructions sent to at least one of said plurality of functional units on said integrated circuit die, or change a

behavior of at least one of said plurality of functional units on said integrated circuit die.

all B31

₩.Π # 3

4

5

6

7